<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
    <meta http-equiv="X-UA-Compatible" content="ie=edge,chrome=1">
    <meta name="referrer" content="never">
    <title>闭包</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        ul {
            list-style: none;
        }
    </style>
</head>
<body>
    
    <script type="text/javascript">
        /* 
        闭包函数：指有权访问另一个函数作用域中变量的函数，这样一种现象称为闭包
        */

        function fn(){
            var a = 10;
            function gn(){
                console.log(++a);
            }

            return gn;
        }

        var gn = fn();
        gn(); // 11
        gn(); // 12
        gn(); // 13

        var f = fn();
        f(); // 11
        f(); // 12
        f(); // 13

        console.clear();

        function func(n, o){
            console.log(o);
            return {
                func: function (m){
                    return func(m, n);
                }
            }
        }

        // var a = func(0);
        // a.func(1);
        // a.func(2);
        // a.func(3);

        // func(0).func(1).func(2).func(3);  // undefined 0 1 2

        var a = func(0).func(1); // undefined 0
        a.func(2); // 1
        a.func(3); // 1
    </script>
</body>
</html>